草庐IT

JavaScript 验证 API

全部标签

ruby - 配置 RSpec 以将 Capybara.javascript_driver 用于所有请求规范

是否可以全局配置RSpec以对所有请求规范使用Capybara的(默认或自定义)JavaScript驱动程序?我们有时会忘记手动将js:true添加到每个请求规范中,这有点烦人。 最佳答案 在spec_helper.rb中,设置以下内容:config.before(:each)doifexample.metadata[:type]==:requestCapybara.current_driver=:selenium#orequivalentjavascriptdriveryouareusingelseCapybara.use_def

ruby - 使用 RSpec 和 VCR 测试 Web API

我正在编写一个作为gem的API包装器,我想使用RSpec测试API响应。问题是所有API请求都是使用GET发出的,并且在url中包含一个APIkey:例如游戏/元数据/{api_key}这给测试带来了问题,因为我不想将APIkey保留在git存储库历史记录中。有什么方法可以进行这些规范测试,最好是使用RSpec/VCR,而不是将APIkey存储在版本控制中?我试过使用环境变量,但VCR仍然存储整个请求,而不仅仅是响应主体。 最佳答案 VCR有一个专门针对这些情况的配置选项:VCR.configuredo|c|c.filter_se

ruby-on-rails - 是否有必要对 ActiveRecord 验证进行单元测试?

是否有必要对ActiveRecord验证进行单元测试,或者它们已经经过充分测试,因此足够可靠? 最佳答案 验证本身应该是可信的,但您可能想检查验证是否存在。换句话说,测试某样东西的好方法就是把它当作一个黑盒子,从实现中抽象出测试,所以例如你可能有一个测试来检查一个人模型是否在没有它的情况下无法保存一个名字,但不关心Person类如何执行该验证。 关于ruby-on-rails-是否有必要对ActiveRecord验证进行单元测试?,我们在StackOverflow上找到一个类似的问题:

ruby-on-rails - Stripe webhook 身份验证 - Ruby

我的ruby​​-on-rails应用程序使用stripe进行卡支付。Stripe提供了webhooks,通过它可以联系回我的应用程序并提供有关每个交易的详细信息-成功或失败。为此,我在我的Controller中有这样的东西:classStripeController我的问题是如何验证此webhook的真实性?据我所知和理解,可以很容易地模仿这一点(中间人攻击)。 最佳答案 来自Stripe的webhooksdocumentation:Ifsecurityisaconcern,orifit'simportanttoconfirmth

ruby-on-rails - 如何使用 omniauth 对服务进行经过身份验证的调用?

我已经从使用OmniAuth的服务中收到了一个token/secret,并且可以为用户存储它,但我不知道如何实际使用这些来调用服务。我见过的最接近这个问题的是here但他解决问题的方式感觉不对。我觉得如果您知道自己在做什么,OmniAuth可能会为您完成这一切。Netflix参与其中authprocess,所以我希望通过使用OmniAuth将我从所有这一切中抽象出来来避开所有这一切。鉴于我有用户的token和secret,如何使用这些来调用像Netflix这样的服务?非常感谢:) 最佳答案 嘿,我是OmniAuthgem的作者。Om

ruby-on-rails - 如何突出显示 Rails 验证错误的字段

在Rails3.1中,如何为未通过验证错误的字段突出显示表单字段?我知道脚手架会自动生成css和Controller代码来处理这个问题,但我想知道是否有办法手动生成它。我已经通过@user.errors.full_messages.each...等实现了错误消息的字符串显示,但我无法让字段以红色突出显示。有什么想法吗?谢谢。 最佳答案 假设您的CSS文件中的字段有一个错误类:"error"%>这是你想要的吗?额外:here'sasectionaboutcustomizingdefaultActiveRecordvalidations

ruby-on-rails - 在 ruby​​ on rails 中使用 facebook graph api 时从 url 获取一个 json 对象

如何在我的ruby​​onrails代码中通过URL获取JSON对象:url="https://graph.facebook.com/me/friends?access_token=XXX"我无法获得有关JSON+RubyonRails的良好教程。谁能帮帮我,谢谢。 最佳答案 require'open-uri'require'json'json_object=JSON.parse(open("https://graph.facebook.com/me/friends?access_token=XXX").read)这是最简单的方法,

ruby-on-rails - before_save 在验证后运行吗?

我的自定义验证似乎在我的before_saveblock之前运行,这对我来说很奇怪。我知道before_validation,但我正在尝试测试我的自定义验证器,所以before_validationHook不允许我这样做。我还读到测试私有(private)方法(我的验证器)是不好的做法。我该怎么办?更多信息:我们希望用户能够上传带有URL或文件的文档,但不能同时上传或不上传(xor)。我的验证器检查这些的异或。如果用户编辑文档,before_saveHook会删除当前的URL或文件。理论上,流程应该是:上传文件验证并保存上传网址before_save、验证、保存但在我的测试中,我收到验

ruby-on-rails - Rails 3. before_destroy 验证以防止删除父记录

我有发货和发票。发票属于出货cargo有一张发票如果货件确实有发票,则不应删除货件。我需要在模型中进行设置,因为我使用的是ActiveAdmin。所以我在shipment.rb中这样做了has_one:invoicebefore_destroy:check_for_invoiceprivatedefcheck_for_invoiceunlessinvoice.nil?self.errors[:base]但我只是收到一条黄色消息,提示“货件无法删除”,但实际上它已被删除。如何防止货件被删除? 最佳答案 before_destroy回调

ruby-on-rails - 通过关联获取 has_many 的 ActiveRecord::RecordInvalid 错误;连接表上的验证问题

我有如下三个关联模型:classProduct当我做类似的事情时:doc=user.documents.builddoc.update_attributes(:product_ids=>[1,2])并且description验证失败,然后我得到false和doc上的相应错误。这正是我想要的。但是,如果doc已经存在,例如:doc=user.documents.firstdoc.update_attributes(:product_ids=>[1,2])并且description验证失败,然后我得到一个ActiveRecord::RecordInvalid错误。我很清楚为什么会这样——i